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(57) Abstract 

A method and an apparatus for preventing the infection of computer systems (10) by computer viruses is disclosed. The 
computer virus monitoring system provides an external security device (15) that stores copies of the host boot sector and file allo- 
cation table, and electronic fingerprints of executable files on the host system disk. The external security device (15) monitors 
writes to the host disk and informs a network monitoring host (26) if the boot sector, file allocation table or electronic fingerprints 
are altered. The network monitoring host (26) responds to such an emergency by saving the status of the host system (12) and 
transferring corrective software to remove the virus. The computer virus monitoring system further provides for periodic scanning 
of the host files to detect and eradicate known viruses. 
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COMPUTER VIRUS MONITORING SYSTEM 



Field Of The Invention 

This invention relates to detection of viruses 
or logic bombs in computer " systems and for taking 
5 responsive action upon such detection. 

Background Of The Invention 

Security of computer systems is becoming 
increasingly important. Computer viruses and logic bombs 
("viruses") are proliferating, and their potential impact 

10 is increasing with the increasing use of network systems. 
Efforts to address the problems posed by viruses have 
included backing up the contents of computer systems on 
magnetic tape or oFher media, and storing the backup in a 
safe location. Such systems are time consuming and 

15 expensive to implement, and only serve to mitigate the 
effects of a problem after a problem has occurred. Others 
have developed software programs, resident on a computer 
system to be protected, to monitor the system for viruses. 
Such protection systems have certain drawbacks: for 

20 instance, because they are resident on a system which may 
become infected, they are similarly subject to disruption 
or corruption. Such systems may also be cumbersome to 
update to respond to newly encountered viruses. 

Summ ar y Of The Invention 

25 it is therefore an object of the invention to 

provide an improved computer virus monitoring system. In 
accordance with the invention, the system includes a 
monitoring computer which is coupled to the system to be 
protected. The monitoring computer monitors the boot 

30 sector and file allocation table of the disk drives of the 
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host system to be protected, and creates and maintains 
identification data for each executable file. The monitor 
detects attempts to alter these files or attempts by a 
file to alter itself or another file and takes appropriate 
5 responsive action to protect the host system from 
unauthorized alteration. The monitor also includes means 
for scanning the host system to detect particular-viruses, 
and to take appropriate protective action upon detection 
of a virus. In a particularly preferred embodiment, such 

10 monitors on a number of host systems are coupled by a 
communication network to facilitate analysis of viruses 
and distribution of antidotes therefor. 

Other objects and features of the invention will 
be understood with reference to the following 

15 specification and claims and the drawings. 

Brief Description Of The Drawings 

Figure 1 is a block diagram showing the basic 
elements of a system in accordance with the invention. 

Figure 2 is a flow diagram illustrating a virus 
20 protection method which may be implemented on the system 
of Figure 1. 

Figure 3 is a flow diagram of a method of 
operating the host system of Figure 1 in accordance with 
the invention. 

2 5 Figute 4 is a flow diagram illustrating a method 

of operation of the monitor of Figure 1 in accordance with 

the invention. 

Figure 5 is a flow diagram illustrating a method 
of operation of the monitor in response to an emergency 
30 condition. 

Figure 6 is a flow diagram illustrating a method 
of communication between monitoring system at a number of 
host locations and a central monitoring system. 
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Figure 7 is a block diagram illustrating the 
basic elements of a preferred embodiment of a security 
device in accordance with the invention. 

Detailed Description of the Invention 

5 Figure 1 is a diagram showing the functional 

elements of the preferred embodiment of the system of the 
present invention. A computer network 10 which is to be 
protected (the "protected network") includes a host system 
12 operating at a customer field site that communicates 

10 with one or more remote systems and communication nodes 18 
via one or more telecommunication devices 16. In a 
typical application, host system 12 may be an IBM 
fileserver, an Apple fileserver, or other computer system. 
Telecommunications device 16 may be a modem, a network 

15 card, or a satellite transceiver, for example. 

Security device 15 monitors the operation of 
host system 12 in three different modes to automatically 
detict viruses and prevent adverse effects. Security 
device 15 monitors the boot sector and file allocation 

20 table (FAT) of disk drives in host system 12. It creates 
and maintains identifying data as a "fingerprint" for each 
executable file. These files should never be altered; 
therefore, if an attempted alteration is detected, 
appropriate protective action may be taken. Finally, 

25 security device 15 scans host system 12 periodically to 
detect particular viruses. 

Security device 15 is coupled to host 12 via a 
parallel connection to the standard architectural bus of 
host 12 in the preferred embodiment; however, security 

30 device 15 may be coupled to host 12 via a serial port in 
an alternate embodiment. Security device 15 is also 
coupled to a security, network monitoring host 26, by a 
telephone line 19 or other communications link. 

Desirably, a number of protected networks 10, 

35 each with its own security device 15, are connected in a 
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network with a security network monitoring host computer 
system 26. Security network monitoring host 26 includes a 
master service database 20 to monitor standard operation 
of security devices 15. It also includes a research 
5 service database 22 which may called by a protected 
network 10 in case of an emergency. Because research 
service database 22 includes storage media such as disk 
drives, it may become infected by a virus. Therefore, 
research database 22 is kept separate from the master 

10 service database 20. Security network monitoring host 
system 26 also includes an antidote software service 
database 24, in which the characteristics of newly 
encountered viruses are stored and in which solutions to 
eradicate them are maintained. Antidote software may be 

15 transferred via master database 20 to security devices 15 
in the monitoring network as needed. 

In a system such as that shown in Figure 1, it 
is important for security device 15 to be as secure and 
reliable as possible. Therefore, security device 15 is 

20 preferably a stand alone unit without a disk drive or any 
other alterable storage device except RAM, to minimize the 
. possibility of infection. Security devices 15 are 
provided with battery backup to maintain operation during 
a power failure. An emergency routine is called when 

25 security device 15 detects tampering, such as an 
unauthorized attempt to open its housing. Communications 
between security network monitoring host 26 and security 
devices 15 or protected networks 10 are desirably 
protected by requiring device-specific electronic 

30 identification numbers (EINs) to initiate communication. 

Figure 2 is a flow diagram showing a method for 
operating a host system 12 and a security device 15 to 
provide virus protection for executable files. In this 
method, an electronic binary •■fingerprint" of identifying 

35 data is created and assigned for each executable file on 
host system disk drive pack. The identifying data is then 
after each write access monitored by security device 15. 
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If the identifying data changes, then security device 15 
will halt the' protected system and initiate a call to the 
research database 22 at security network monitoring host 
26. 

5 The process of Figure 2 for monitoring the 

software of the protected system starts in step 50 and new 
software is added to the protected system in step 52. In 
step 54 the fingerprint, which can be conventionally 
generated as a check sum, a cyclic redundancy check (CRC) 

10 or other error detecting coding scheme, is created to 
provide an identifying code that is unique to the file. 
In a preferred embodiment, the fingerprint is generated by 
host system 12, although in alternate embodiments the 
fingerprint could be generated on security device 15 or on 

15 a dedicated circuit card. The fingerprint is saved on 
host system 12 in step 58, and on security device 15 in 
step 56. Steps 60 and 62 provide an ongoing process, for 
determining the status of the software by monitoring the 
fingerprint. The host fingerprint *s read in step 60. In 

20 step 62 the host fingerprint is compared with the 
corresponding fingerprint in security device 15. If the 
host fingerprint has not changed, .the process returns from 
step 62 to step 60 to continue the monitoring process. If 
the fingerprint has changed, then in step 64 security 

25 device 15 halts operation of host system 12. Security 
device 15 then initiates a call to the system operator of 
host system 12 in step 68, and in the preferred 
embodiment, a call to the research database 22 of security 
network monitoring host 26 in step 70. Also in response 

30 to detection in st<:;> 62 of a fingerprint change, security 
device 15 attempts in step 72 to destroy the virus which 
caused . the -fingerprint change. 

The process of destroying the virus involves 
comparison of the contents of files stored on host 12 with 

35 characteristics of known viruses stored in security device 
15 downloaded from master database 20 of network host 26. 
If characteristics of a known virus are detected, antidote 
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software, stored in antidote software database 24, is 
executed to destroy the virus in step 74. Upon successful 
detection and destruction of a virus, a report of this 
activity is generated in step 76, transmitted to the 
5 research database 22 of security network monitoring host^ 
26 in step 78, and transmitted to the system operator of 
host system 12 in step 80. Step 82 returns the process to 
step 54, in which a new fingerprint is created, and then 
saved. Host system 12 may thereafter continue its 

10 operation free from the virus. If in step 74 the virus 
has not been successfully destroyed, a further call is 
initiated by security device 15 to research database 22 
for further assistance in identification and destruction 
of the virus, while operation of host system 12 is 

15 disabled to prevent consequential damage from the virus. 

Figure 3 is a flow diagram of the operation of 
host system 12 relating to " security device 15. 
Initialization steps of host system 12 include porting the 
boot sector and FAT of host system 12 to security device 

20 15 in steps 90 and 92 respectively, creating a fingerprint 
file in step 94 and porting the fingerprint file to 
security device 15 in step 96. In the host monitoring 
process, security device 15 monitors write access signals 
in step 102, indicating an instruction to write to a disk. 

25 When a write access signal is received, host system 12 
provides information to security device 15 to use in tests 
to verify system integrity and virus free inputs In step 
104, host system 12 sends a write access interrupt to 
security device 15. In step 106, security device 15 reads 

30 its interrupt status" to determine whether the emergency 
interrupt flag is set. If an emergency interrupt is 
indicated, the keyboard is locked and host 12 is halted in 
step 108. In step 110 the write access is examined to 
determine whether it seeks to write to an existing 

35 executable file; if so, in step 112 the keyboard is locked 
and host system 12 is halted. Otherwise, in step 114 the 
write access is examined to determine whether it seeks to 
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write a new executable file' or batch. If so, in step 116 
host 12 calls a scan routine from security device 15 and 
executes it. The scan routine examines the file to be 
written for viruses and the like. If the scan indicates 
5 the presence of a virus or the like, step 118 directs the 
process to step 120, where an emergency interrupt is sent 
to security device 15, and step 122, where the keyboard is 
locked and host system 12 is halted. If in step 118 no 
viruses or other problems have been detected, or if step 

10 114 has determined that the write access is not for a new 
executable file, the file may be written to disk. In step 
124, host system 12 updates the PAT on security device 15, 
creates new fingerprints in step 126, and updates the 
fingerprint data on security device 15 in step 128. 

15 Host system 12 also, waits for interrupt from 

security device 15 to run tests to verify the entire 
system is virus-free. This is done to determine at what 
time any system errors occur to help with data recovery in 
case that becomes necessary. Thus, in step 130 if a 

20 fingerprint interrupt is received from security device 15, 
host system 12 in step 132 ports its fingerprint data to 
security device 15. If host system 12 then receives a 
fingerprint emergency interrupt from security device 15 in 
step 134, it locks the keyboard and halts host system 12 

25 in step 136; otherwise, control is passed to step 138 and 
host system 12 returns to its start status in 100. If in 
step 140 a scan interrupt is received from security device 
15, host system 12 calls the scan routine from security 
device 15 and executes it in step 142. If no viruses or 

30 the like are detected in the scan, step 144 directs a 
return to the start status via step 138. If, however, the 
scan process results in the detection of a virus or the 
like, in step 146 an emergency interrupt is sent to 
security device 15 and host system 12 is halted and its 

35 keyboard locked in step 148. 

Figure 4 is a flow diagram illustrating the 
operation of security device 15. Security device i5 
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initialization includes steps 150, 152, and 154, where 
boot sector, FAT, and fingerprints ("CRCs") of host 12 are 
copied and mapped into security device 15 memory. 

The security device 15 monitoring process starts 
5 in step 156, and in step 158 security device 15 monitors 
the host until a write access interrupt is received from 
the host. In step 160, security device 15 compares the 
boot sector files stored in its memory with the boot 
sector files stored in host system 12. If these are not 

10 the same, step 162 directs the process to an emergency 
state in step 164. If the boot sector files are 
determined to be the same as in step 162, step 166 
determines whether the write access seeks to write to a 
.EXE, .COM file, or the like. If so, security device 15 

15 goes to an emergency state in step 168 and follows the 
emergency procedure shown in Figure 5. If not, step 170 
determines whether the write access seeks to write a new 
executable file. If so, step 172 scans the file to be 
written to determine whether it contains any viruses. If 

20 the test is not passed, "security device 15 is directed in 
step 174 to go to an emergency state in step 176. If the 
test in step 174 is passed, or. if in step 170 the write 
access was not for a new executable file, the file may be 
written.. In step 178, the FAT is updated on host system 

25 12 and security device 15, and in step 180 fingerprint 
data for the file is created on the host 12 and updated 
fingerprint data is sent to security device 15. 

In addition to monitoring initiated upon write 
accesses, security device 15 also automatically 

30 periodically monitors fingerprint data and scans for 
viruses. In step 182, if an internal clock in security 
device 15~indicates that it is time for a fingerprint 
check, in step 184 the fingerprint data stored in security 
device 15 is compared with the current fingerprint data of 

35 host system 12. If the fingerprint data is the same, step 
194 directs the process to step 190 and a return to start 
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condition 154. If the fingerprint data is different, 
security device 15 goes to an emergency state in step 196. 

In step 186, if security device 15 clock 
indicates that it is time to perform a scan, a scan is 
5 performed in step 188 to determine whether the contents of 
host system 12 contain any viruses or the like by 
comparison with identifying data stored in security device 
15. If the scan detects no such code, step 192 directs 
the process to the start condition through step 190? if 
10 virus is detected, security device 15 goes to an emergency 

state in step 198. 

Figure 5 is a flow diagram illustrating 
emergency condition operation of security device 15, which 
starts at step 200. A security device 15 sends an 

15 emergency interrupt to host system 12 in step 202, 
instructing host system 12 in step 204 to close all files 
and return to the DOS prompt (or an equivalent prompt in a 
non-DOS system.)., and in step 206 to lock the keyboard and 
halt operation. This action isolates the virus in host 

20 system 12. Host system 12 remains locked until the proper 
unlock password is entered in step 208, in which event 
host system 12 will unlock the keyboard in step 210 and 
save the status to disk in step 212, display the status in 
step 214, and write the status to the printer in step 216. 

25 in addition to Sending an emergency interrupt to 

host" system 12, in the preferred embodiment security 
device 15 is~connected in a network, and in step 218 calls 
the monitoring host 26. In step 220, security device 15 
identifies itself by sending a login code and the 

30 electronic identification number for the particular 
security device 15. If the electronic identification 
number is accepted, security device 15 will be permitted 
to login to the research database, a call is generated to 
the monitoring network system operator in step 222, and 

35 the status of the protected network 10 which generated the 
emergency condition is displayed in step 224. After the 
monitoring network system operator identifies and corrects 
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the problem which generated the emergency condition, the 
system operator resets security device 15 in step 222, and 
normal operation of protected network 10 resumes in step 

228. ~ 
5 Figure 6 is a flow diagram illustrating the 

operation of network monitoring system 26. In step 250, 
network monitoring system 26 is responding to a connect 
attempt initiated by a security device 15, in step 218 of 
Figure 5. In step 252, network monitoring system 26 

10 prompts security device 15 for its EIN and login code. In 
step 220, security device 15 sends its logon code and EIN 
to network monitoring system 26. In step 254, network 
monitoring system 26 checks the received EIN and logon 
code to verify that the communication was initiated by a 

15 legitimate security device 15, not by a computer hacker. 
To ensure the security of the system, a preferred 
embodiment of the invention uses a 128 bit EIN. In a 
preferred embodiment, network monitoring host 26 waits 
only a limited amount of time, approximately 9 seconds, to 

20 receive logon information after it detects a carrier 
signal on the telephone link. The combination of a 128 
bit EIN and a limited time to respond effectively 
eliminates the possibility of a hacker logging onto the 
system. If network monitoring system 26 detects an 

25 invalid EIN or a time-out condition, it disconnects the 
telephone hookup in step 256. If network monitoring 
system 26 detects a valid" EIN in step 254, the logon 
procedure is executed in step 258. 

In step 260, network monitoring system 26 

30 determines whether or not the call is an emergency call. 
If the call is an emergency call, the status of host 
system 12 is saved in research database 22 in step 272, 
displayed in step 274 and printed out in step 276, so that 
the virus can be isolated. In parallel with steps 272, 

35 274 and 276, a call is generated by an emergency routine 
within host 12 to the system operator of network 
monitoring system 26 in step 278. In step 280, network 
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monitoring system 26 checks whethex_ host system 12 has 
been reset. Once host system 12 has been reset, a logoff 
procedure is followed in step 282 and network monitoring 
system 26 disconnects telephone link 19 from security 
5 device 15 to research database 22 in step 284, 

If , in step 260/ network —monitoring system 26 
determines that the call is not an emergency call, it 
checks in step 262 whether the call is a report call. If 
the call is not a report call, the system operator is 

10 called in step 264 and network monitoring system 26 enters 
terminal mode. If the call is a report call, network 
monitoring system 26 creates a report file including the 
time and date in step 266, stores the report file in step 
268 and prints the file in step 270, After the file is 

15 sent to the printer, network monitoring host 26 initiates 
a logoff procedure in step 282 and disconnects the 
telephone link from security device 15 in step 284. 

Figure 7"~is a block diagram of a preferred 
embodiment of security device 15. Security device 15 

20 includes a processor 300 connected to a control bus 354, a 
data bus 356 and an address bus 358. Processor 300 
communicates through buses 354, 356 and 358 to read only 
memory (ROM) 306, random access memory (RAM) 308, I/O 
interface 320, I/O interface 316 and liquid crystal 

25 display (LCD) driver 310. Processor 300 further includes 
an input from Clock 302 and from Reset Input 304. LCD 
driver 310 is coupled through LCD interface 312 to LCD 
314. LCD 314 is used by security device 15 to display 
status information to a maintenance technician or an 

30 engineer, to aid in isolating a virus found in host system 
12. Security device 15 includes ROM 306 and RAM 308 as 
storage devices. ROM 306 is utilized for storing the 
firmware which controls processor 300. RAM 308 is used by 
Processor 300 to store temporary information, including 

35 fingerprint files, boot sector information and file access 
table information. Security device 15 communicates with 
host 12 through I/O interface 320. I/O interface 320 is 
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preferably coupled to file transfer area 14 of host 12 via 
a parallel connection f although in another embodiment a 
serial port is utilized. Security device 15 is assigned a 
random address location in the memory space of host system 

5 12, so that a Hacker cannot try to access RAM 308. 
Security device 15 is coupled to modem 318 through I/O 
interface 316. Security device 15 uses modem 318 to 
access the master database 20 of host of network 
monitoring system 26 through telephone line 19. 

0 it is to be understood that the foregoing is 

merely illustrative of the principles of this invention, 
and that various modifications can be made by those 
skilled in the art without departing from the scope and 
spirit of the invention. 
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What Is Claimed Is; 

1. A monitoring system for detecting software 
viruses in a host computer system having a host memory and 
a file storage memory; for storing an executable software"* 
5 file by means of a write access, said monitoring system 
comprising: 

means for generating an electronic 
fingerprint of the executable software file 
when the file is written to the file 
xo storage memory by means of a first write 

access; 

a security device coupled to the host 
computer, said security device comprising 
means for monitoring write accesses of the 

15 fii e storage memory, fingerprint memory 

means for storing a copy of the fingerprint 
and emergency interrupt response means for 
halting and locking the host computer in 
response to an emergency interrupt; 

20 means for transferring a first copy of 

the fingerprint to the fingerprint memory 
of the security device and for transferring 
a second copy of the fingerprint to the 
host memory; and 

25 comparison means for comparing the 

first copy of the fingerprint stored- in 
fingerprint memory with the second copy of 
the fingerprint stored in the host memory 
when ~a subsequent write "access of the 

30 executable software file occurs and for 

generating an emergency interrupt to the 
security device if the first and second 
copies are not identical. 
2« The system of claim 1, wherein the host 

35 computer system includes the fingerprint generation means. 
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3. The system of claim 1, wherein the security 
device includes the fingerprint generation means. 

4. The system of claim 2, wherein the 
electronic fingerprint is a checksum code, 

5 5* The system of claim 2, wherein the 

electronic fingerprint is a cyclic redundancy check code. 

6. The system of claim 1, wherein the host 
computer includes the comparison means. 

7. The system of claim l f wherein the security 
10 device includes the comparison means. 

8. A monitoring system for detecting software 
viruses in a protected network including a host computer 
coupled to a remote computer system, the host computer 
having a host memory and a host file storage memory for 

15 storing a software file by means of a write access, the 
monitoring system comprising: 

means for generating an electronic 
fingerprint of the software file when the 
file is written to the file storage memory; 

20 "Ss- a security device coupled to the host 

computer, said security device comprising 
means for monitoring write accesses of the 
file storage memory, fingerprint memory 
means for storing a copy of the fingerprint 

25 and emergency interrupt response means for 

halting and locking the host computer in 
response to an emergency interrupt; 

means for transferring a first copy of 
the fingerprint to the fingerprint memory 

30 of the security device and for transferring 

a second copy of the fingerprint to the 
host memory; and 

comparison means for comparing the 
first copy of the fingerprint stored in 

35 fingerprint memory with the second copy of 

the fingerprint stored in the host memory 
when a subsequent write access of the 
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software file occurs and for generating an 
emergency interrupt to the security device 
if the first and second copies are not 
identical. 

5 9. The system of claim 8, further comprising: 

means r in the security device, for 
storing a copy of the file allocation table 
of the host computer system; and 

comparison means responsive to a write 
10 access of file storage memory, for 

comparing the copy of the file allocation 
table stored in the security device memory 
means with the file allocation table stored 
in the host system when a write access 
15 occurs and for generating an emergency if 

the copy of the file access table is not 
identical to the file allocation table 
stored in the host system. 

10. The system of claims , further comprising: 
20 mearis for copying the boot sector of 

the host computer system to the memory 
means in the security device; and 

comparison means for comparing the 
copy of the boot sector stored in the 

25 security device memory with the boot sector 

stored in the host memory when a write 
access occurs and for generating an 
emergency interrupt if the copy of the boot 
sector is not identical to the boot sector 

30 of the host system. 

11. The system of claim 8, further comprising a 
network -monitoring system coupled to the security device 
and to the host system, for monitoring a plurality of 
security devices. 

35 12. The system of claim 11, wherein the network 

monitoring system further comprises a research database 
for compiling performance characteristics for each 
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security device and protected network, and an antidote 
software database for storing software to overcome known 
computer viruses . 

13. The system of claim 12, wherein the 
5 research database contains known computer virus cod€" 

patterns. 

14. The system of claim 13, further comprising 
means for scanning the host file storage memory to detect 
the known software viruses stored in the research 

10 database. 

15. A method for protecting a host computer 
system including a file storage memory from infection by a 
software virus, comprising the steps of: 

generating an electronic fingerprint 
15 for an executable software file being 

stored in the file storage memory; 

storing a first" copy of- the electronic 
fingerprint in the host memory and storing 
a second copy of the electronic fingerprint 
20 in an external security device; 

monitoring write accesses to the file 
storage memory; 

comparing the first and second copies 
of the fingerprint whenever the write 
25 access occurs; and 

halting and locking the host computer 
when the first and second copies of - the 
fingerprint differ, indicating the possible 
presence of a virus, so that the virus 
30 cannot damage the host computer system. 

16. The method of claim 15, further comprising 
the steps of: 

transferring a copy of the boot sector 
of the host computer system to the security 
35 device memory; 

periodically comparing the copy of the 
boot sector with the host boot sector to 



WO 93/25024 



PCT/US93/05029 



-17- 

determine whether the host boot sector has 
changed; and 

if the host boot selector has changed, 
halting and locking the host computer, 
5 system to prevent possible damage by a 

virus. 

17. The method of claim 16 further comprising 
the steps of: 

transferring a copy of the file 
10 allocation table of the host computer 

system to the security device memory: 

periodically comparing the file 
allocation table with the copy of the file 
allocation table stored in the security 
15 device memory to determine whether its 

fingerprint has changed; and 

if the file allocation table has 
changed, halting and locking the host 
computer system to prevent possible damage 
20 by a virus. 

18. The method of claim 17, further comprising 

the steps of: 

storing known computer virus code 
patterns in a first database;. 
25 storing antidote software for said 

known computer virus code patterns in a 
second database; 

periodically scanning the file storage 
memory of the host computer system for said 
30 known computer virus code patterns; and 

halting the host computer system and 
executing said antidote software if a virus 
is detected. 
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